<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .father{
            position: relative;
            height: 100px;
            width: 100px;
            background-color: palevioletred;
            margin: 50px;
            /* padding: 2px; */

        }
        .son{
            width: 20px;
            height: 20px;
            background-color: purple;
            margin-left: 10px;
        }
    </style>
</head>
<body>
    <div class="father">123
        <div class="son">
            555
        </div>
    </div>
    <button>按钮</button>
    <script>
        //offset 偏移量  可以动态得到该元素的位置（偏移）、大小等
        //element.offsetParent 返回作为该元素带有定位的父级元素 如果父级元素没有定位则返回body
        var btn = document.querySelector('button');
        var father = document.querySelector('.father');
        var son =document.querySelector('.son');
        console.log(son.offsetParent);
        btn.addEventListener('click',function(){
            console.log(father.offsetTop); 
        })
        //element.offsetLeft返回元素相对带有定位的父元素的左边框的偏移
        console.log(father.offsetLeft);
        //element.offsetWidth 返回自身包括padding 、边框、内容区的宽度
        console.log(btn.offsetWidth);
        //element.offserHeight 返回自身包括padding 、边框、内容区高度
        console.log(father.offsetHeight);
    </script>
</body>
</html>